{% extends 'basic.html' %}
{% load static %}
{% block title %}
    用户注册
{% endblock %}

{% block css %}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
    <style>
        .error-msg {
            color: red;
            position: absolute;
            font-size: 13px;
        }
        #btnSms:hover{
            background-color: lightgray;
        }
        .account{
            border-radius: 15px;
            box-shadow: 15px 15px 15px 10px lightgray;
        }
    </style>
{% endblock %}

{% block content %}

    <div class="account">
        <div class="title">用户注册</div>
        <form id="regForm" method="POST" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row ">
                            <div class="col-xs-7" style="margin-left: 13px; width: 300px">
                                {{ field }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-xs-5" style="margin-left: 80px;">
                                <input id="btnSms" type="button" class="btn btn-default" value="点击获取验证码"
                                       style="border-radius: 15px;border: 1px lightgray solid;">
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}

            <div class="row">
                <div class="col-xs-3" style="margin-left: 13px">
                    <input id="btnSubmit" type="button" class="btn btn-primary" value="注  册"/>
                </div>
            </div>
        </form>
    </div>
{% endblock %}

{% block js %}
    <script>
        //当整个页面框架加载完成以后自动执行函数
        $(function () {
            BindclickSms();
            BindRegister();
        });

        /*
         点击获取验证码的绑定事件
        */
        function BindclickSms() {
            $('#btnSms').click(function () {
                $('.error-msg').empty()
                //由于申请不到短信服务，暂时使用邮箱来发送验证码
                //拿到用户输入的邮箱
                var email = $('#id_email').val()
                //发送ajax请求
                $.ajax({
                    url: "{% url 'send_sms' %}", //提交的地址
                    type: 'GET',   // 提交的方法
                    data: {email: email,},   // 提交的数据，字典形式
                    dataType: 'JSON',  //将服务端返回的数据反序列化为字典
                    success: function (res) {
                        // ajax请求发送成功后，自动执行, res就是后端返回的值
                        if (res.status) {
                            sendSmsRemind();
                        } else {
                            //错误信息
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0]);
                            })
                        }
                    }
                })
            })
        }

        /*
        * 验证码倒计时
        * */
        function sendSmsRemind() {
            var $btnSms = $('#btnSms');
            $btnSms.prop('disabled', true);   //禁用点击
            var time = 60
            clearInterval(remind); // 先清除可能存在的旧定时器
            var remind = setInterval(() => {
                $btnSms.val(time + '秒重新发送');
                time = time - 1;
                if (time < 1) {
                    clearInterval(remind);
                    $btnSms.val('点击获取验证码').prop('disabled', false);
                }
            }, 1000)
        }

        /*
        * 点击注册
        * */
        function BindRegister() {
            $('#btnSubmit').click(function () {
                //每次点击先清空错误信息
                $('.error-msg').empty()
                {#//先拿到用户输入的各项数据#}
                {#var username = $('#id_username').val()#}
                {#var email = $('#id_email').val()#}
                {#var password = $('#id_password').val()#}
                {#var confirmPassword = $('#id-confirm_password').val()#}
                {#var mobilePhone = $('#id_mobile_phone').val()#}
                {#var code = $('#id_code').val()#}

                //发送ajax请求把数据给到后端
                $.ajax({
                    url: '{% url 'register' %}',
                    type: 'POST',
                    data: $('#regForm').serialize(), // 所有字段数据 + csrf token
                    dataType: 'JSON',
                    success: function (res) {
                        if (res.status){
                            location.href = res.data
                        }else {
                            // 错误信息
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0])
                            })
                        }
                    }
                })
            })
        }
    </script>
{% endblock %}
